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This application note describes a PWM 
(Pulse Width Modulation) scheme for 
motor speed control. A state of the art 
CMOS logic circuit uses a ROM (Read 
Only Memory) to generate sineweighted 
pulse trains. The memory organization is 
such that four pulse trains, with fixed- 
phase differences between their modula- 
tion envelopes, are produced to control 
single, two or three phase motors. Opto- 
electronic couplers are used to isolate 
logic and power stages. The availability 
of four-phase shifted drive signals and the 
isolation afforded by optical coupling pro- 
vides a means of using a single logic 
stage to control multiple and mixed-type 
motor installations. 
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INTRODUCTION 

The utilization of ac machines for variable -speed motor 
drives is increasing. The relatively short lifetimes of the 
brushes in a dc machine, and their associated maintenance 
requirements, makes the ac motor an attractive alterna- 
tive for applications ranging from small machine control 
to large traction drive schemes. 

The speed of an ac induction motor can be controlled 
by varying the voltage or frequency of the motor's power 
source. The variable voltage approach is generally used to 
control shaded pole, permanent split capacitor, wound 
rotor or universal motors. Variable frequency drives are 
most often used to power polyphase machines of integral 
horsepower rating. 

Two methods of producing variable-frequency drives 
include cycloconverters and pulse width modulators 
(PWM). The cycloconverter synthesizes lower frequency 
ac by combining the three phases of standard 50/60 Hz 
power in certain patterns. The PWM inverter operates 
from a dc source; by switching SCRs or power transistors 
at certain rates, sine waves of current can be approximated 
in the motor windings. 

The PWM scheme to be described in this Note utilizes 
state of the art CMOS (complementary metal oxide semi- 
conductor) logic. A stored program contained in a 256 
by 4 bit CMOS ROM (Read Only Memory) generates 
the appropriate sine-weighted pulse trains. The memory 
programming is such that four pulse trains, with fixed 
phase differences between their modulation envelopes, 
are produced to control single, two or three phase ac 
motors. Optoelectronic couplers are used to interface 
logic and power stages. 

Ordinarily, PWM inverters are used to drive three phase 
ac motors. While the majority of present day applications 
may require such machines, the control of single and two 
phase motors may also be desirable. For example, mills, 
lathes and other related shop machinery use single, two or 
three phase motors coupled to gear or pulley transmissions 
to effect speed control. Elimination of the transmission by 
means of a variable speed drive can result in a machine 
with feWer moving parts and lower weight . 

The CMOS logic circuit to be described, in conjunction 
with suitable power stages, can provide variable frequency 
drive for single, two or three phase motors. The optical 
couplers, used for interfacing, have a unidirectional signal 
characteristic; this property minimizes transient feedback 
from the power stages to the logic stage. In addition, the 



optical coupler provides an easy means of translating the 
drive signals from the low voltage logic supply level to the 
high voltage, bidirectional power switch levels. 



SYSTEM OPERATION 

ROM Addressing 

The control scheme is shown, in block form, in Fig- 
ure 1. The MCM14524, a 1024 bit, (organized 256 by 
4), mask-programmable CMOS memory is used to gener- 
ate the sine-weighted PWM waveform. In this scheme, 
the memory outputs form four serial words each 256 
bits long. Since 256 = 2**, an 8 bit address is required. 
A 12 bit binary counter, MC14040, and two MC14507 
quad exclusive-OR gates form the addressing logic to 
generate an up-down count pattern; the address cycles 
from Word (000000002) to Word 255 (IIIIIIII2) 
back to Word 0, and so on. When the address is changing 
from Word to Word 255, the average value of the ROM 
output BO approximates a sine wave from 0° to 90°; when 
the address is changing from Word 255 to Word the 
average value approximates a sine wave from 90° to 
180°, as shown in Figure 2. 

One output of a simple CMOS R-C oscillator, Clock 
#1, controls the counter in the address logic. A second 
output, Clock #2, controls data transfer within the mem- 
ory. Clock #2 is a delayed version of Clock #1. The 
delay, of approximately 3 jus, allows the counter to settle 
to a new state before the data in the memory is trans- 
ferred to the outputs B0 through B3. The oscillator sets 
the rate at which the address changes, and consequently, 
controls the frequency of the drive signals applied to a 
motor's windings. The drive signal frequency range is 
from 10 Hz to 100 Hz. In short, the oscillator serves 
as the RPM control. 



ROM Data Steering 

To minimize the bit capacity requirements of a mem- 
ory, only quarter cycle waveform coding need be stored 
when the desired waveforms are periodic sine-cosine waves. 
The output data of the memory can then be switched, or 
steered, through logic gates, to form pulse trains whose 
composite waveforms have the desired periodicity. 



Circuit diagrams external to Motorola products are included as a means of illustrating typical semiconductor applications; consequently, 
complete information sufficient for construction purposes is not necessarily given. The information in this Application Note has been care- 
fully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information 
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A1 -A8: Power Switches 



FIGURE 1 - Block Diagram 








FIGURE 2 - Changes at B0 with Respect to 
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Memory output BO contains sine coding from 0° to 
90°. Referring to Figures 1, 2 and 3, when the address 
changes from WO to W255 and back to WO, a polarity 
control signal from the data steering logic switches the 
BO bit stream from a power stage (Al), that operates from 
a positive voltage bus to a stage (A2) that operates from a 
negative voltage bus. The combination of a count up/count 
down address, a polarity switching signal that occurs at 
180° (512 address changes), the ROM sine programming 
and the voltage polarity change at the power stages pro- 
duces a PWM drive signal, 6, with a sinusoidal current 
envelope. 

The programming for Bl is the inverse of BO; that is to 
say, there is a sine-cosine relationship between BO and Bl , 
as shown in Figure 3. In a manner similar to that used 
to produce 6, a drive signal 6 + 90° is generated using 
Bl. These two signals, 6 and 6 + 90°, can be used to 
drive a two phase motor. Either signal, or in fact, either 
of the two remaining outputs, 6 + 120° and 6 + 240°, 
can be used to drive a single phase motor. 

The last two outputs of the memory, B2 and B3, are 
used to produce the two drive signals, 6 + 120° and 6 + 
240°. As their names imply, these drive signals are 120° 
with respect to each other and also to 6. Used together, 



6,6 + 120° and 6 + 240°, provide drive signals for a three 
phase motor. To achieve the proper phasing for three 
phase drive, the programming for B2 and B3 is somewhat 
different from that of B0 and Bl. Output B2 contains 
sine coding that ranges from 60°, through 0°, to 30°; B3 
ranges from 60°, through 90°, to 30°. The fundamental 
difference between (B0, Bl) and (B2, B3) is that (B0, Bl) 
both contain sine data for 0° and 90°; B2 and B3 do not. 
B2 has sine data that passes through 0°; B3 has sine data 
that passes through 90°. In order to generate two com- 
posite wave forms that differ by 120° with respect to 
6, B2 and B3 must be shared, or multiplexed, to form 
6 + 120° and 6 + 240°. In essence, B2 provides sine data 
around 0° for 5 + 120° and 6 + 240°; B3 provides data 
around 90°. Figure 3 shows the relationships between the 
memory outputs and drive signals with respect to the 
memory address. 

Voltage polarity switching for 6 + 120° and 6 + 240° 
must occur, obviously, at 120° and 240° respectively, 
with regard to 6. Since the absolute sine values of 120° 
and 240° are equal to the sine value at 60°, a circuit is 
employed to detect the memory address that is equivalent 
to an absolute sine value of 60°. The output of this word 
detector circuit is used to control the steering of the B2, 
B3 bit streams in the multiplexer logic. 
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SINE CODING IN THE ROM 

Each memory output represents a 90° segment of a sine 
modulated envelope. Figure 4 describes the coding for 
ROM output B0. The first quadrant of a sine wave was 
divided into eight equal angle steps and the sine value at 
each division was determined. Each step was allotted 32 
bits of memory. In this scheme, a logic "1" level pro- 
duces an ON condition at a power stage. Sine values were 
equated to duty cycle/step. The ideal ON bits/step (duty 
cycle/step x 32) represent the most accurate sine weight- 
ing per step. However, since fractional bits cannot be 
obtained, the ON bits were rounded off to integer values. 
The sine weighted modulation envelope illustrates one way 
in which the memory could be patterned. The actual 
output from B0 is a modified version of the sine weighted 
envelope. The ON bits/step were divided into smaller 
groups, with the result that a waveform of 68 steps/cycle 
of output drive is produced at the power stage. The reason 
for this modification was to improve motor operation at 
low speeds by reducing the effects of cogging. This 
jerking motion, or cogging, as the rotor turns at slow 
speeds, is related to the number of steps in the drive wave- 
form and the inertia of the motor load. The greater the 
number of steps, the smoother the rotor turns at low 
speeds. While a large number of steps can improve low 
speed operation, too large a number can adversely affect 
high speed operation. In this scheme, the smallest ON 
or OFF step is equal to three memory bit intervals. At an 
output drive frequency of 100 Hz, for example, the time 
interval per bit is 9.75 (is (bit time = 1 /output frequency 
x 1024). This 30 /us interval is adequate to switch most 
and some of the newer thyristors. 
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Memory outputs Bl, B2 and B3 have the same ON/ 
OFF bit patterns as BO; they differ only in the way their 
sine coding is stored with respect to the pattern of BO. 
Figure 5 shows the program stored in the MCM14524 
memory. Examination of the program will show that the 
pattern of Bl, when going from Word 255 to Word 0, is 
the same as the pattern of BO, when moving from Word 
to Word 255. Also, the pattern of B2, when starting 
from Word 170 and going in either direction, is the same 
as the pattern of BO, when starting from Word 0. Lastly, 
the pattern of B3, with Word 170 as the starting point, is 
the same as the pattern of Bl, when starting at Word 0. 

ROM ADDRESSING AND CONSTRUCTION OF AND 
6 + 90° OUTPUTS 

Refer to Figures 6, 7 and 8. The ROM address inputs 
AO through A7 are initiated in the first 8 outputs of the 
MCI 4040 12-bit binary up counter, U6. Assume an 
initial state of logic zero ("0") at all the counter outputs. 
Clock #1 advances the counter outputs Ql through Q8 
from 000000002 to 1 1 1 1 1 1 1 1 2 in 256 clock pulses. At 
the 257th pulse, Q9 returns to "1". As mentioned 



earlier in this text, the memory requires an up-down count 
pattern at the address inputs. This is achieved by com- 
bining the outputs of Ql through Q8 with the output of 
Q9 in MCI 4507 Exclusive-OR gates U7 through U14. 
Since the output of the Exclusive-OR is 



B = AB + AB 



then a truth table for Q9 © (Ql . . . , Q8) would be 

Q9 



(Ql . . . , Q8) 





'"o 


1 * 








1 




1 






Thus it can be seen that when Q9 is at "0", the binary 
value of Ql through Q8 remains the same, but when Q9 
is "1", the complement of Ql through Q8 is present at the 
output of the gates. In the first quadrant, as shown in 
Figure 2, the sine value of BO increases from "0" to "1". 
In the second quadrant, as the address counts down, BO 
decreases back to a sine value of "0". This provides one 
alternation of output 6, via buffer U32. At the beginning 
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FIGURE 5 - ROM Programming for 256 x 4 Bit Organization 
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Motorola 
Part No. 

MC14572 
MC 14572 
MC 14040 
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MCI 4050 
MC 14050 
MC14519 
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FIGURE 6 - Logic Diagram 



of the third quadrant, Q10 of the binary counter changes 
to a "1" level. At this time, the bit stream from BO is 
switched to buffer U33. The optical couplers associated 
with U32 and U33 control a pair of power stages that 
connect a load to positive and negative voltage supplies, 
respectively. Q10 remains at a "1" level until the end of 
the fourth quadrant. 

The construction of output + 90° is similar to that of 
output (refer to Figures 6 and 8). The difference occurs 
in the polarity switching points for + 90° Output 
$ + 90° requires a change in polarity at the beginning of 
the second and fourth quadrants. This is accomplished by 



Exclusive-ORing Q9 and Ql in U24. In the first quadrant, 
Bl, changing from sine value = 1 to sine value = 0, is 
routed to buffer U34. In the second quadrant, Bl is 
switched to U35. Bl is routed through U35 for the second 
and third quadrants. During this interval, Bl sine value 
changes from "0" to "1 " back to "0". At the beginning of 
the fourth quadrant, Bl is switched back to U34. The op- 
tical couplers connected to U34 and U35 are part of a 
power stage similar to that described in the generation of 
output 0. In this manner, a drive signal in quadrature 
to is generated. 
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FIGURE 7 - Interrelationship of Logic Signals and Output 
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FIGURE 8 - Generation of and d + 90° Outputs 



CONSTRUCTION OF 9 + 120° AND 9 + 240° OUTPUTS 

Unlike the 9 and + 90° outputs, the + 120° and 
6 + 240° outputs require bit stream multiplexing of B2 
and B3. As described previously, the "end" point values 
of B2 and B3 are equivalent to the sines of 60° and 30°. 
To construct a drive waveform that is displaced 120° from 
6, an absolute sine value of 60° is required. When 9 has 
changed from 0° to 90°, a waveform displaced 120° 
must change to a sine value equivalent to 210°. The 
absolute sine value of 210° is 30°. For a waveform 
displaced 240°, the same absolute sine values are re- 
quired. Both B2 and B3 meet these requirements; however, 
since 9 + 120° requires a lead angle of 120°, B2 is chosen. 
Consider that, when 9 reaches 60°, 9 + 120° must be at 



"0" sine value. B2 has a "0" sine value at that time. 
With output 9 as a reference, as shown in Figure 3, 
output 9 + 120° will be generated, initially, by B2. 
Output 9 + 240° will begin with B3. 

Polarity switching of 9 and 9 + 90° occurs every 90° 
at address W0. Polarity switching of 9 + 120° must 
occur at 60° and 240°, with respect to 9. In the same 
regard, switching of 9 + 240° must occur at 120° and 
300°. These switching points have absolute sine values 
equal to 60°. 

A switching signal that occurs at 60°, 120°, 240° and 
300° can be obtained from the ROM address pattern. 
Word 170 is equivalent to an angle of 59.75°. This word 
is used to switch the polarity of 9 + 120° and 9 + 240°. 
A word detector, as shown on Figure 6, consisting of gates 
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U16 through U20, provides a clock pulse for the D 
type flip-flop U45 when the memory address is W170 
(101010102). Refer, also, to Figure 9. The flip-flop is used 
as a storage element. Since Wl 70 only occurs once during 
a quadrant, the flip-flop prevents the polarity of + 120° 
and + 240° from changing after the Wl 70 switching signal 
has occurred. During the first quadrant, before W170, 
B2 is routed through gate U42 to the XI , Y3 inputs of 
multiplexer U40. The MC14519 4-bit AND/OR Selector 
is used as a four pole, double throw switch. When the 
U40 control inputs A and B are "1" and "0" respectively, 
data at the X inputs are transferred to the Z outputs of the 
Selector. When control input A is "0" and B is "1", data 
at the Y inputs is transferred. U6 Q9 and inverter U23 
control the A and B inputs of U40. During the first and 
third quadrants, X data is passed through U40; during the 
second and fourth, Y data is transferred. From W0 to 
W170 of the first quadrant, B2 is routed to buffer U37 
and the positive voltage control optical coupler of + 
120°. At W170, flip flop U45 changes state, thereby 
inhibiting gate U42 and allowing gate U41 to transfer 
B2 data. B2 passes from X0 to Z0 of U40 to buffer 
U36 to the negative voltage control coupler of + 120°. 
At the beginning of the second quadrant, U40 switches to 
its Y data inputs. ROM B3 output is then transferred to 
buffer U36 (see Figure 9). At this time, B2 and B3 both 
have an absolute sine value of 30° and an exchange of bit 
patterns is made without discontinuities. Also at this 
time, the ROM address inputs begin to count down. This 
causes the bit pattern of B3 to be generated in reverse 
order. At the beginning of quadrant three, the + 120° 
output picks up B2 again. B2 and B3 now have absolute 
sine values of 60°. B2 bit pattern is now generated in re- 
verse order. Polarity switching for + 120° takes place 
at W170 of quadrant three. At the beginning of quadrant 
four, bit stream switching between + 120° and + 
240° outputs take place. At the beginning of the first 
quadrant, second cycle, B2 is switched into + 120° and 
the process repeats. Composition of + 240° is similar to 
that of + 120° and can be mapped with the aid of 
Figures 6 and 9. 

OUTPUT POWER STAGES 

A transistor power stage is shown in Figure 10. The 
voltage ratings of the devices make this quasi-complemen- 
tary configuration suitable for transformerless, 110 Vac 
line operation. The 4N26 optical couplers have an isola- 
tion rating of 1500 V; this allows the power stages to 
float 1500 V above the logic, should that be necessary. 
By increasing the drive capability of the logic outputs, by 
means of emitter followers, etc, the LED's (Light Emit- 
ting Diodes) of many couplers can be paralleled at each 
output. In this manner, extra power stages could be added 
in different configurations to drive a variety of motors 
simultaneously. 



CONCLUSION 

Three different subfractional-horsepower motors were 
driven by the circuit. These standard, 60 Hz motors were 
a 1/50 hp, 1725 rpm, shaded pole type; a 1/50 hp, 1725 
rpm, permanent -split capacitor type; and a 1/75 hp, 3,300 
rpm, three phase type. Each motor operated over a range 
from base speed to approximately 5% of base speed. Be- 
low 5%, audible indications of cogging occurred; above 
base speed, the torque output drops rapidly. Figure 1 1 
shows the wave forms of the output of a power stage. 

An objective of the work presented here was to devise 
a logic scheme that could provide PWM signals for a 
variety of ac motors. Standard CMOS logic was used, 
since CMOS offers excellent noise immunity and tolerance 
to power supply voltage variations. Additionally, the low 
power requirement of CMOS makes this type of logic 
ideally suited to high density chip architecture and could 
eventually result in a compact logic circuit containing 
only a few LSI devices. 
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FIGURE 9 - Generation of + 120° and 6 + 240° Outputs 
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FIGURE 10 - Single Phase Power Stage - Transistor Version 



H = 2.0 ms/div. 
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Comparison of a Sine Wave and the 68 Step Current Waveform 
FIGURE 1 1 - Current and Voltage Waveforms at the Output of a Power Stage 




MOTOROLA Semiconductor Products Inc. 



